- 
          
- 
                Notifications
    You must be signed in to change notification settings 
- Fork 646
Update to Python 3.7 interpreter for build tooling #447
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Conversation
| This proposal merges to dev branch as part of the v4.000 release work in #427 | 
| Just received word from the Semaphore CI team that there is now support for Py 3.7 testing. Will attempt to fix these tests this week. This PR has been on hold as we waited for this CI testing support. | 
| Initial attempt didn't fix this. Still working on it with the Semaphore CI team | 
| Closing in favor of a new PR that only includes a Py37 interpreter upgrade. I bumped the Python build tooling dependencies here with pipenv and there is going to be some troubleshooting required to make that move. With the Python tooling bump, ttfautohint fails because it looks like there has been a conversion away from builds with glyph production names in at least some cases. | 
| 
 See ufo2ft 2.4 release notes https://github.com/googlei18n/ufo2ft/releases/tag/v2.4.0 and | 
| if you relied on the previous behavior whereby all the glyphs where renamed to uniXXXX production names based on their unicode value (and your UFO lib.plist does not contain an explicit public.postscriptNames mapping), you can pass  | 
| @anthrotype Thanks Cosimo. I think that the only place where this is required in the build process is at the ttfautohint control instructions files style assignments. We were using the previous default production names from the fontmake 1.5 compiles there. This will be simple to update. Probably simpler than figuring out why pipenv will not permit me to maintain a deterministic build tool set with a Python interpreter version bump. For some reason it is bumping versions of fontmake deps when I try this despite requests to leave them be. :) | 
| @anthrotype is there a simple way to get the new glyph names in the binaries by unicode code point values (from the previous production names) with fonttools? | 
| or do these come from the GlyphData.xml mapping? | 
| The uniXXXX production names are generated by ufo2ft postProcessor based on the glyph's unicode values, they don't come from GlyphData.xml. The latter is used by glyphsLib to create the public.postcriptNames mapping, which is then applied by ufo2ft postProcessor, when it is present. Anyway, as I said, if you were happy with the previous glyph production names, just call fontmake with the  <key>com.github.googlei18n.ufo2ft.useProductionNames</key>
<true/> | 
| sorry I misstyped the lib key: the correct one is  | 
| @anthrotype I would prefer to convert to default behavior with fontmake and this will require modification of the ttfautohint control instruction files. I need to change the glyph names in those files to match what is in the binary after a build with fontmake. Is it safe to assume that this is the glyph name defined in *.glif files after this change in the compile tooling? If not, I need to know where the unicode : name map is or figure out a way to search for the glyph name by unicode hex value in the binary. | 
| The default behaviour is no glyph renaming unless a public.postscriptNames mapping is present in lib.plist. | 
| Thanks Cosimo. Appreciate all of your help! | 
| Worked fine with the glyph name replacements in the control instructions files.  It looks like there was a transition to  | 
| 
 Where do you see these diffs? | 
| ttx dump of fonts built with previous Pipfile.lock and built with new Pipfile.lock. | 
| can you be more specific? e.g. paste an example of such diffs? | 
| and it looks like it is a change to ceil from round, not ceil from floor. Some X and Y vals in contour definitions are shifted up by 1 unit c/w previous build. Occurs infrequently relative to all definitions but there are a large number of the changes. Somewhere between 900-1000 per variant binary. | 
| i believe it might be a change introduced in fonttools 3.28: 
 fonttools/fonttools#1248 The change is for the good, I recommend you go on with the update. | 
| yeah, looks good to me. read on in the linked issues above for more info | 
| Will be reviewing the fonts visually before we release. This should not cause major problems. ttfautohint did pick up on the fact that things changed in rare cases across each of the font variants. There were < 10 instruction set changes in each file | 
| 
 Thanks for taking a look!! Much appreciated | 


This PR also updates all Python tooling in the toolchain to current release versions on PyPI.